草庐IT

json - 从 url 读取 json

全部标签

ruby-on-rails - Rails 点而不是 URL 中的斜线

在我的routes.rb我有:get"projects/:category_id"=>"projects#index"当我编写projects_path(1)时,生成的URL是/projects.1而不是/projects/1。你知道为什么会这样吗?这是rakeroutes的输出:GET/projects/:category_id(.:format)projects#index 最佳答案 projects_path是索引,它只接受一个参数:格式。你想要project_path(1) 关于

ruby-on-rails - Rails 3 中图像路径的完整 url

我有一张图片,其中包含载波上传:Image.find(:first).image.url#=>"/uploads/image/4d90/display_foo.jpg"在我看来,我想为此找到绝对url。附加root_url导致双/。root_url+image.url#=>http://localhost:3000//uploads/image/4d90/display_foo.jpg我不能使用url_for(据我所知),因为要么允许传递路径,或选项列表以标识资源和:only_path选项.因为我没有可以通过“controller”+“action”识别的资源,所以我不能使用:only

ruby - Kernel#gets 尝试读取文件而不是标准输入

我是Ruby的新手,今天我编写了一个应用程序,您可以通过ARGV向其传递参数。但在我的应用程序中,我希望能够使用“gets”。问题是,每次我尝试这样做时,都会出现错误。这是一个显示我的问题的简单脚本:print"Saysomething!"input=gets如果我这样调用它:$rubyscript.rbthisisarguments我收到这个错误:script.rb:2:in`gets':Nosuchfileordirectory-this(Errno::ENOENT)fromscript.rb:2希望有人能帮我解决这个问题,这样我就可以继续我的Ruby之旅。:)编辑:我知道“Get

ruby-on-rails - 您将如何解析 Ruby 中的 url 以获取主域?

我希望能够使用Ruby解析任何URL以获取没有www的域的主要部分(只是example.com) 最佳答案 请注意没有算法方法可以找到可以为特定顶级域注册域的最高级别(每个注册管理机构的政策不同),唯一的方法是创建所有顶级域的列表以及域可以注册的级别。这就是为什么PublicSuffixList存在。我是PublicSuffix的作者,一个将域分解为不同部分的Ruby库。举个例子require'uri/http'uri=URI.parse("http://toolbar.google.com")domain=PublicSuffix

ruby - 将整个文本文件作为单个字符串读取的合理方法是什么?

我相信这很容易;我无法立即从Google找到答案。我知道我可以做到这一点(对吧?):text=""File.open(path).each_linedo|line|text+=lineend#Dosomethingwithtext但这似乎有点过分,不是吗?或者这是人们在Ruby中的做法吗? 最佳答案 IO.read()正是您要找的。File是IO的子类,所以你也可以使用:text=File.read(path)没有比这更直观的了。 关于ruby-将整个文本文件作为单个字符串读取的合理方法

ruby-on-rails - rails : URL/path with parameters

我想生成一个URL作为/swimming/students/get_times/2013-01-01/2013-02-02从这条路线get_class_swimming_studentsGET/swimming/students/get_times/:start_date/:end_date(.:format)swimming/students#get_times如何将参数传递给get_class_swimming_students_path? 最佳答案 get_class_swimming_students_path('2013-

ruby - 从 href html 标签中使用 ruby​​ 中的 nokogiri 提取链接(URL)?

我想从网页中提取所有URL,如何使用nokogiri做到这一点?例子:site1site2site3resultshouldbeanlist:l=['http://example.org/site/1/','http://example.org/site/2/','http://example.org/site/3/' 最佳答案 你可以这样做:doc=Nokogiri::HTML.parse(site1site2site3site4site5site6HTML_ENDl=doc.css('div.heata').map{|link|

ruby - 读取文件时如何避免被 UTF-8 BOM 绊倒

我正在使用最近添加了UnicodeBOMheader(U+FEFF)的数据提要,现在我的rake任务被它搞砸了。我可以使用file.gets[3..-1]跳过前3个字节,但是是否有更优雅的方式来读取Ruby中的文件,它可以正确处理这个问题,无论BOM是有没有? 最佳答案 在ruby​​1.9.2中,您可以使用模式r:bom|utf-8text_without_bom=nil#definethevariableoutsidetheblocktokeepthedataFile.open('file.txt',"r:bom|utf-8")

ruby-on-rails - 如何设置 ActionMailer default_url_options 的 :host dynamically to the request's hostname?

我正在尝试设置:hostforactionmailer默认url选项。我在所有环境文件中设置了以下内容config.action_mailer.default_url_options={:host=>"localhost"}我想通过提供请求主机使其更具动态性。当我尝试通过设置它时config.action_mailer.default_url_options={:host=>request.domain}或config.action_mailer.default_url_options={:host=>request.env["SERVER_NAME"]}它抛出错误...无法识别“请求

ruby-on-rails - rails : respond_to JSON and HTML

我有一个Controller“UserController”,它应该响应对http://localhost:3000/user/3的正常请求和ajax请求。当是正常请求时,我要渲染我的View。当是AJAX请求时,我想返回JSON。正确的方法似乎是respond_todo|format|block。编写JSON很容易,但我怎样才能让它响应HTML并像往常一样简单地呈现View呢?defshow@user=User.find(params[:id])respond_todo|format|format.html{render:show????thisseemsunnecessary.Ca